#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<vector>
#include<stack>
using namespace std;
class MinStack {
public:
    MinStack() {

    }

    void push(int val) {
        st.push(val);
        if (minst.empty() || val <= minst.top())
            minst.push(val);
    }

    void pop() {
        if (st.top() == minst.top())
            minst.pop();
        st.pop();
    }

    int top() {
        return st.top();
    }

    int getMin() {
        return minst.top();
    }
private:
    stack<int> st;
    stack<int> minst;
};
int main()
{
    MinStack st;
    st.push(1);
    st.push(2);
    st.push(3);
    st.push(4);
    st.push(5);
    cout << st.getMin() << endl;
    return 0;
}